package main.java;

/**
 * @program: pratice
 * @author: 关键我是大怪
 * @create: 2021-10-03 15:28
 */

/**
 * 题目：
 * 某种外星语也使用英文小写字母，但可能顺序 order 不同。字母表的顺序（order）是一些小写字母的排列。
 * 给定一组用外星语书写的单词 words，以及其字母表的顺序 order，只有当给定的单词在这种外星语中按字典序排列时，返回 true；否则，返回 false。
 * <p>
 * 示例：
 * 输入：words = ["hello","leetcode"], order = "hlabcdefgijkmnopqrstuvwxyz"
 * 输出：true
 * 解释：在该语言的字母表中，'h' 位于 'l' 之前，所以单词序列是按字典序排列的。
 */

public class Test47_外星语言是否排序 {
    public boolean isAlienSorted(String[] words, String order) {
        int n = words.length;
        for (int i = 1; i < n; i++) {
            String cur = words[i];
            String pre = words[i - 1];
            int j = 0, k = 0, x = pre.length(), y = cur.length();
            while (j < x && k < y) {
                int p = order.indexOf(pre.substring(j, j + 1));
                int q = order.indexOf(cur.substring(k, k + 1));
                if (p < q) {
                    break;
                }
                if (p > q) {
                    return false;
                }
                j++;
                k++;
            }
            if (j < x && k == y) {
                return false;
            }
        }
        return true;
    }
}
